import Vue from 'vue'
import App from './App.vue'
import router from './router'
// import './plugins/element.js'
// 导入全局样式
import './assets/css/global.css'
// 导入NProgress进度条的js和css
import NProgress from 'nprogress'
import 'nprogress/nprogress.css'
// 导入axios
import axios from 'axios'
import store from './store'
// table 表格展开行
import tableTree from 'vue-table-with-tree-grid'
// 文本编辑器
import VueQuillEditor from 'vue-quill-editor'
// 文本编辑器样式
import 'quill/dist/quill.core.css'
import 'quill/dist/quill.snow.css'
import 'quill/dist/quill.bubble.css'

Vue.config.productionTip = false
    // 设置请求的根路径
axios.defaults.baseURL = 'http://127.0.0.1:8888/api/private/v1/'
    // 对请求进行预处理
axios.interceptors.request.use((config) => {
    // 发起请求展示进度条
    NProgress.start()
        // 请求拦截器添加token
    config.headers.Authorization = window.sessionStorage.getItem('token')
    return config
})
axios.interceptors.response.use((config) => {
        // 响应时关闭进度条
        NProgress.done()
        return config
    })
    // 挂载至vue的原型对象上
Vue.prototype.$http = axios

// 全局注册表格展开行组件
Vue.component('table-tree', tableTree)
    // 注册文本编辑器
Vue.use(VueQuillEditor)

// 全局过滤器  过滤时间
Vue.filter('dateFormate', (originVal) => {
    const time = new Date(originVal)
    const y = time.getFullYear()
        // 获取月份 不足两位用0补充
    const m = (time.getMonth() + 1 + '').padStart(2, '0')
    const d = time.getDay().toString().padStart(2, '0')
    const hh = time.getHours().toString().padStart(2, '0')
    const mm = time.getMinutes().toString().padStart(2, '0')
    const ss = time.getSeconds().toString().padStart(2, '0')
    return `${y}-${m}-${d} ${hh}:${mm}:${ss}`
})

new Vue({
    router,
    store,
    render: (h) => h(App)
}).$mount('#app')